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A METHOD AND SYSTEM FOR SERVER BASED SOFTWARE PRODUCT 

RELEASE VERSION TRACKING 

This application claims the benefit of earlier filed provisional application serial 
number 60/271,330, filed on 2/23/01. 

5 FIELD OF THE INVENTION 

The field of the present invention pertains to software product 
development. More particularly, the present invention relates to a method and 
system for monitoring software products as they flow through the various 
stages of software development and efficiently implementing a tracking 
10 system for managing updates and changes. 

BACKGROUND OF THE INVENTION 

One of the most important societal changes of recent times has been 
the emergence of information systems, more particularly, digital computer 

15 systems, for managing and accessing information, entertainment, etc. Digital 
information systems (e.g., the Internet) have emerged as a predominant 
communications medium. Digital information systems enable the navigable 
aggregation of information, for example Web page content, among all the 
connected devices. A fundamental component of virtually all digital 

20 information systems is the software based applications which provide their 
functionality. Software applications general refers to software based 
components, programs, products, and the like which when executed by a digital 
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computer system device (e.g., desktop computer system, handheld computer 
system, cellphone, etc.) implement the device functionality for the user. 

Software applications are typically developed by teams specialists (e.g., 
5 programmers, software engineers, etc.). Programmers, or software application 
authors, typically use specialized software to design and build a software 
application. For example, a set of specialized software applications (e.g., a 
software development toolkit, or "SDK") can be used to help programmers 
write an application. For building software application graphical interfaces, 

10 the SDK provides the tools and libraries for creating menus, dialog boxes, fonts 
and icons. The SDK provides the means to link the application to libraries of 
software routines and to link it with the operating environment (OS, DBMS, 
protocol, etc.). A typical SDK can also include a programming language and 
related components. It can include the compiler, text editor, debugger, function 

15 library and any other supporting programs that enable a programmer to write 
a program. SDKs are generally designed to make the process of designing and 
building software applications more efficient. 

A well-known problem exists however due to the fact that, despite the 
20 use of SDKs, complex software applications can take many months, or even 
years, to complete. A complex software applications can involve large teams 
of software engineers working cooperatively on various parts of the application 
simultaneously. Accordingly, keeping track of such a large project such as a 
development of a complex software application is extremely critical task. 
25 Many large software projects have ultimately failed due to lack of configuration 
management. 
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As known by those skilled in the art, configuration management with 
respect to software development refers to a systematic method and 
mechanism for keeping track of large projects. Although prior art 'Version 
control" schemes, which maintain a database of revisions, is part of such a 
system, a full-blown software configuration management system (SCM 
system or CM system) must at minimum automatically document all 
components used to build the various executable program building blocks of a 
project. Prior art software configuration management systems are typically 
able to recreate each "build" as well as to recreate earlier builds in order to 
maintain previous versions of a product. Prior art software configuration 
management systems may also be used to prevent unauthorized access to 
files or to alert the appropriate users when a file has been altered. 

Prior art software configuration management systems have a number 
problems. A typical SCM system is separate from the software development 
process. For example, engineers must go through elaborate procedures in order 
to "checkout" software from a central repository in order to make updates or 
changes during a design and development process. These same procedures 
typically also apply during a quality assurance process as the software is 
carefully tested and prepared for release. Prior art SCM systems also utilize 
inefficient mechanisms for accessing previous versions of a software product. 
Usually, only the most recent releases are available to the 
development/quality assurance engineers. Where access is allowed to multiple 
previous versions, there often exists problems in keeping track of the different 
versions of the software product. Additionally, the check-in/check-out 
mechanisms of many prior art SCM systems increase the amount of time 
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required, for example, for software product debugging between various 
versions. 

Thus, what is required is a way to simplify the process of maintaining a 
5 software product version tracking system. What is required is a solution that 
renders the software configuration management process much easier than the 
prior art. What is required is a solution that simplifies the changing and 
maintaining of different software product versions within a software 
development/software quality assurance environment. The present invention 
10 provides a novel solution to these requirements. 
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SUMMARY OF THE INVENTION 

The present invention provides a way to simplify the process of 
maintaining a software product version tracking system. The present 
invention provides a solution that renders the software configuration 
5 management process much easier than the prior art. The present invention 
provides a solution that simplifies the changing and maintaining of different 
software product versions within a software development/software quality 
assurance environment. 

10 In one embodiment, the present invention is implemented as a 

client/server based software product release version tracking method. The 
method functions in part by maintaining software product version tracking in a 
client/server computer system environment. The method includes the step of 
storing a plurality of software product versions within a database. A plurality 

15 of directories of the database are traversed to determine paths for each of the 
software product versions. The traversing is performed by a server. As the 
design or quality assurance process progresses, at least one of the software 
product versions is select for updating (e.g., by a quality assurance engineer), 
the selecting performed by one of a plurality of clients. The one software 

20 product version is edited using the one client and a resulting new software 
product version (e.g., containing the changes or alterations) is subsequently 
returned to the database. Using the server, the directories of the database are 
updated to chronologically track the new software product version and to 
ensure the paths for each of the software product versions, including the new 

25 software product version, are available to the clients. 
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In another embodiment, a software based server component can be 
executed on the server computer system in order to make the new software 
product version visible to the clients. Using the server, the method can include 
creating a file containing the paths for each of the software product versions, 
5 the file used by the clients to access to software product versions. Using the 
server, a chronological arrangement of the software product versions can be 
maintained and a tree data structure for tracking one or more chronological 
arrangements of the software product versions can be maintained. A number 
of tree data structures can be maintained, for example, one tree structure for 
10 each software development project or software development quality assurance 
^ group, which can be accessed via the graphical user interface of the clients. 

01 In another embodiment, a software based client component can be 

5 executed on the client computer system. The client component can generate a 

W 15 graphical user interface for the presentation of software product version 
O information to the engineers (e.g., on a workstation display). The graphical 

n 

III user interface can, for example, visually depict the tree data structures that 

Q track the various software product versions. 

20 Thus, a number of engineers can alter, modify, redefine, and otherwise 

manage the software product versions of an entire project through the intuitive 
graphical user interface representation of the client component. In this 
manner, the present invention provides a solution that renders the update and 
maintenance process of a number of software product versions of, for example, 

25 a large software project, much easier than the prior art, and simplifies the 
changing and maintaining of software product versions within a database. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example and not by way of 
limitation, in the figures of the accompanying drawings and in which like 
reference numerals refer to similar elements and in which: 

5 

Figure 1 shows a diagram of a software product version tracking system 
in accordance with one embodiment of the present invention. 

Figure 2 shows a flowchart of the steps of a first process in accordance 
10 with one embodiment of the present invention is shown. 

Figure 3 shows a flowchart of the steps of a second process in 
accordance with one embodiment of the present invention. 

15 Figure 4 shows the user's view of the product server component through 

the graphical user interface in accordance with one embodiment of the present 
invention. 

Figure 5 shows a tree structure view of the directory tree structure 
20 created by the client component in accordance with one embodiment of the 
present invention. 

Figure 6 shows the case where the user selects a desired item to be 
downloaded to client machine in accordance with one embodiment of the 
25 present invention. 
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Figure 7 shows the graphical user interface presentation where the 
target location for download does not exist, and the user is prompted for 
creating a target directory for the download in accordance with one 
embodiment of the present invention. 

5 

Figure 8 shows the graphical user interface presentation to the user 
once the the download process has begun in accordance with one embodiment 
of the present invention. 

10 Figure 9 shows the graphical user interface presentation of the source 

and target paths of the download in order to allow the user to verify the correct 
file(s) were transferred in accordance with one embodiment of the present 
invention, 

15 Figure 10 shows the comparing functionality presentation seen by the 

user when to different software product versions are compared in accordance 
with one embodiment of the present invention. 

Figure 11 shows a presentation depicting the results of a comparison in 
20 accordance with one embodiment of the present invention. 

Figure 12 shows the components of a computer system platform in 
accordance with one embodiment of the present invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

Reference will now be made in detail to the embodiments of the 
invention, examples of which are illustrated in the accompanying drawings. 
While the invention will be described in conjunction with the preferred 
5 embodiments, it will be understood that they are not intended to limit the 

invention to these embodiments. On the contrary, the invention is intended to 
cover alternatives, modifications and equivalents, which may be included 
within the spirit and scope of the invention as defined by the appended claims. 
Furthermore, in the following detailed description of the present invention, 

10 numerous specific details are set forth in order to provide a thorough 

understanding of the present invention. However, it will be obvious to one of 
ordinary skill in the art that the present invention may be practiced without 
these specific details. In other instances, well known methods, procedures, 
components, and circuits have not been described in detail as not to 

15 unnecessarily obscure aspects of the present invention. 



Embodiments of the present invention are directed towards a computer 
implemented method for maintaining software product version tracking. The 
present invention provides a solution that renders the software configuration 
20 management process much easier than the prior art. The present invention 
provides a solution that simplifies the changing and maintaining of different 
software product versions within a software development/software quality 
assurance environment. The present invention and its benefits are further 
described below. 
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Notation and Nomenclature 

Some portions of the detailed descriptions which follow are presented in 
terms of procedures, steps, logic blocks, processing, and other symbolic 
representations of operations on data bits within a computer memory. These 
5 descriptions and representations are the means used by those skilled in the 
data processing arts to most effectively convey the substance of their work to 
others skilled in the art. A procedure, computer executed step, logic block, 
process, etc., is here, and generally, conceived to be a self-consistent sequence 
of steps or instructions leading to a desired result. The steps are those 

10 requiring physical manipulations of physical quantities. Usually, though not 
necessarily, these quantities take the form of electrical or magnetic signals 
capable of being stored, transferred, combined, compared, and otherwise 
manipulated in a computer system. It has proven convenient at times, 
principally for reasons of common usage, to refer to these signals as bits, 

15 values, elements, symbols, characters, terms, numbers, or the like. 

It should be borne in mind, however, that all of these and similar terms 
are to be associated with the appropriate physical quantities and are merely 
convenient labels applied to these quantities. Unless specifically stated 

20 otherwise as apparent from the following discussions, it is appreciated that 
throughout the present invention, discussions utilizing terms such as 
"processing" or "computing" or "communicating" or "instantiating" or 
"registering" or "displaying" or the like, refer to the action and processes of a 
computer system (e.g., computer system 512 of Figure 12), or similar 

25 electronic computing device, that manipulates and transforms data 

represented as physical (electronic) quantities within the computer system's 
registers and memories into other data similarly represented as physical 
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quantities within the computer system memories or registers or other such 
information storage, transmission or display devices. 

Method and System of the Invention 

5 Figure 1 shows a diagram of a software product version tracking system 

100 in accordance with one embodiment of the present invention. As depicted 
in Figure 1, the tracking system 100 includes a client computer system 110 
(hereafter client 110) coupled to a server computer system 120 (hereafter 
server 120) via a network 130. A software based client component 111 

10 executes on the computer system platform of client 110. Client component 
111 generates a graphical user interface 112 for interacting with a user. A 
software based server component 125 executes on the computer system 
platform of server 120. Aversion path file 121 and associated directory tree 
data structures 122 are maintained on the server 120. A database 123 

15 containing a plurality of software product versions 124 is also maintained on 
the server computer system 120. 

Referring to system 100 of the present embodiment, system 100 
functions by providing a client/server based software product version tracking 

20 process. The product version tracking process is used by, for example, a 

software design group as the group works on a number of software components 
of a large project. Software product version tracking is an integral part of 
software configuration management. As is well known, software configuration 
management is indispensable to the successful completion of large software 

25 design projects. A large software design project can encompass a project 
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taking, for example, 10 engineers three months to complete, or even 1000 
engineers (or more) three years (or more) to complete. 



System 100 is a client/server based computer system. A client/server 
5 computer system environment is used for maintaining software product 

version tracking in order to efficiently provide access to the software product 
versions by a large number of users. In this embodiment, each of the users 
(e.g., typically software engineers, quality assurance engineers, or the like) 
access a plurality of software product versions 124 via their respective client 
10 computer systems. One such client 110 is shown in Figure 1. 

A server component 125 executes on the computer system platform 
provided by server 120. The server component 125 interacts with client 110 to 
provide requested software product versions retrieved from database 123 and 
15 to receive updated software product versions from client 110 and store them 
within database 123. The server component 125 interacts with the version 
path file 121 and the database 123 in order to implement the software product 
version tracking functionality of the present embodiment. 

20 In the present embodiment, system 100 stores each of the software 

product versions (e.g., product versions 124) within the database 123. The 
software product versions can be stored as images (e.g., copies) within the data 
schema of database 123. Database 123 thus functions as a repository for 
each of the software product versions that are generated. Database 123 can 

25 be implemented using a number of different database products. 
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Referring still to system 100 of the present embodiment, version path 
file 121 functions in part as a directory of each of the software product 
versions 124 stored within database 123. In the present embodiment, the 
version path file 121 is created by and maintained by server component 125. 
5 In updating the version path file 121, server component 125 traverses a 

plurality of directories of the database 123 to determine paths for each of the 
plurality of software product versions 124. 

A directory tree structure 122 is used to catalog file paths to the product 
10 versions 124. Server component 125 traverses through the data schemas of 
database 123 in order to determine accurate file paths for each of the software 
product versions 124 stored therein. This information is stored in directory 
tree structure 122. The directory tree structure 122 provides a logical and 
intuitive data structure for viewing the relationships between the various 
15 software product versions 124. For example, to determine the relationship 
between a number of different software product versions, the directory tree 
structure can be accessed and viewed via the graphical user interface 112 of 
client computer system 110. 

20 The software product versions are edited using the client computer 

systems. For example, new software product versions are created by editing 
an earlier software product version. The earlier software product version is 
selected from the product versions 124 using the graphical user interface 112. 
In the present embodiment, an image of the earlier software product version is 

25 transferred from the server 120 to the client 110. For example, the user can 
graphically selected the desired earlier software product version by clicking on 
the earlier version in the depicted directory tree (e.g., corresponding to the 
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directory tree structure 122) and then assigning a location to which the earlier 
version will be downloaded. The earlier software product version is then edited 
using the one client and a resulting new software product version is 
subsequently returned from client 110 to the server 120. Server component 
125 then stores the new software product version within the database 123 and 
updates the directory tree structure 122 of version path file 121 to reflect the 
new software product version. 

Using server component 125, the directory tree structure 122 of the 
database is updated to chronologically track the new software product version 
to ensure the paths for each of the plurality of software product versions and 
the new software product version are available to the plurality of clients. A 
plurality of tree data structures 122 can be maintained, for example, one tree 
structure 122 for each software development project or software development 
quality assurance group, which can be accessed via the graphical user 
interface 112 of the clients. 

Referring still to system 100 Figure 1, system 100 provides for 
comprehensive software product version control and maintains a database 
123 containing the large number of revisions and different versions 124 and 
automatically documents all software product versions used, for example, to 
build large executable programs. By maintaining a database 123 of all the 
previous product versions 124, system 100 is able to recreate each "build" as 
well as to recreate earlier environments in order to maintain previous versions 
of a product. 
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The maintaining of all previous product versions 124 provides for 
comprehensive regression testing. In case of error or nonfunctional code, 
system 100 is able to support comprehensive regression testing in order to "roll 
back" to a previous version in the event of errors or problems with new 
5 software product versions. For example, previous versions can be downloaded 
to client 110 and compared with later versions in order to discover the exact 
point at which an error or bug was introduced. Differences within the code can 
be pinpointed to make the debugging process more efficient. 

10 Since system 100 is based upon a client/server architecture, system 

100 can utilize a secure login system in order to prevent unauthorized access 
to files, or to alert the appropriate users when a file has been altered. For 
example, each client can be required to provide a secure login in order to gain 
access to the product versions 124. Additionally, different product versions 

15 can be restricted to different groups of users. For example, different software 
groups can have access to their respective directory tree 122 and associated 
product versions 124, while being blocked from access to other directory trees 
122 and other product versions 124. 

20 Thus, system 100 provides a number of advantages. The product 

version tracking system of the present invention is an integral part of the 
software development process. For example, in a typical embodiment, at any 
given time of a software quality assurance process, each of the versions of the 
product in the testing state are available to a software quality assurance 

25 group. The versions are made available without requiring the engineers to go 
through elaborate procedures in order to "checkout" software from a central 
repository. This results in an increase of efficiency since it shortens the time 
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required for testing setup. Additionally, by decoupling the process of software 
quality assurance from the software design, a quality assurance group will not 
be interfering in the creation of each new version and can have access limited 
to authorized versions. Therefore, for example, software quality assurance 
5 groups can avoid wasting time in testing a non-valid version. An additional 
advantage is the fact that since the product versions 124 are maintained in 
central server 120, each accessing quality assurance engineer will be working 
on the same image, resulting in a unified testing process. 

10 Referring now to Figure 2, a flowchart of the steps of a process 200 in 

accordance with one embodiment of the present invention is shown. Process 
200 shows the steps performed by server component 125 in implementing a 
software product version tracking process in accordance with a system 100 
embodiment of the present invention. 

15 

Process 200 begins in step 201, where a plurality of software product 
versions 124 are stored within database 123 by the server component 125. In 
step 202, a plurality of directories of the database 123 are traversed to 
determine paths for each of the plurality of software product versions 124. 

20 The result of the traversing is one or more directory tree structures 122 stored 
in a version path file 121. As described above, the version path file 121 
contains the paths to each of the software product versions 124. In step 203, 
in response to a selection from the client 110, one of the software product 
versions is retrieved from database 123 and transferred via network 130 to the 

25 client component 111 of the client 110. 
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Referring still to process 200 of Figure 2, in step 204, a resulting new 
software product version is received from the client 110 and is stored within 
database 123. As described above, editing and/or changes to the software 
product version checked out by client 110 are performed on client 110. The 
resulting new software product version is checked back into the database 123 
via the server component 125. Subsequently, in step 205, the directory tree 
structure 122 and the version path file 121 are updated by server component 
125 to reflect the new software product version. As described above, the 
directory tree structure 122 in the version path file 121 can be updated to 
chronologically track the new software product version to ensure the paths for 
each of the plurality of software product versions and the new software 
product version are available to the plurality of clients. 

Referring now to Figure 3, a flowchart of the steps of the process 300 in 
accordance with one embodiment of the present invention is shown. Process 
300 shows the steps performed by a client component 111 in implementing a 
software product version tracking process in accordance with a system 100 
embodiment of the present invention. 

Process 300 begins in step 301, were the user as indicates his access 
level to system 100. As described above, a login procedure can be used, 
wherein users having different access levels login to system 100 using different 
passwords. In step 302, a user, through the graphical user interface 112, 
accesses the directory tree structure 122 and selects an appropriate one of 
directory trees 122 (e.g., the directory tree corresponding to the user's product 
division). The interaction between the server 120 and the graphical user 
interface 112 is accomplished by the client component 111. In step 303, once 
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the specific directory tree 122 has been selected, the user selects the specific 
project with which he is working. In step 304, the user then selects the specific 
software product version he wishes to download to the client 110. In step 305, 
the download is initiated. As described above, the user provides the destination 
5 directory to which the software product version will be downloaded. In step 
306, testing is performed on the downloaded software product version and 
changes are made. In step 307, the resulting new software product version is 
checked back into the database 123 via the graphical user interface 112. 

10 Referring now to Figures 4 through 11, a series of graphical user 

interface presentations as depicted by the graphical user interface 112 are 
shown. Figures 4 through 11 illustrate the different graphical user interface 
presentations provided to a user as the user interacts with the client 
component 111 and the server component 125 of system 100. For example, 

15 Figures 4 through 11 illustrate the user's interaction with the directory tree 
structure 122 during the process of selecting and downloading a software 
product version. 

Figure 4 shows the users view of the product server component 125 
20 through the graphical user interface 112. Figure 5 shows the tree structure 
view of the directory tree structure 122 created by the client component 111. 
Figure 6 shows the case where the user selects (e.g., double-clicks) a desired 
software product version to be download to client machine 110. The user is 
prompted for a location for the download. Figure 7 shows the graphical user 
25 interface presentation wherein the target location for download does not exist, 
and the user is prompted for creating a target directory for the download. 
Figure 8 shows the presentation to the user once the the download process has 
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begun. Figure 9 shows the source and target paths of the download in order to 
allow the user to verify the correct file(s) were transferred. Figure 10 shows 
the comparing functionality presentation seen by the user when two different 
software product versions are compared. As described above, such a 
comparison can be used during regression testing. Figure 11 shows a 
presentation depicting the results of a comparison. 

Computer System Platform 

With reference now to Figure 12, a computer system 512 in accordance 
with one embodiment of the present invention is shown. Computer system 
512 shows the components of a computer system in accordance with one 
embodiment of the present invention that provides the execution platform for 
implementing certain software based functionality of the present invention. 
As described above, certain processes and steps of the present invention are 
realized, in one embodiment, as a series of instructions (e.g., software program) 
that reside within computer readable memory units of a computer system 
(e.g., system 512) and are executed by the processor(s) of system 512. When 
executed, the instructions cause the computer system 512 to implement the 
functionality of the present invention as described above. 

In general, computer system 512 shows the basic components of a 
computer system used to implement "server" machines and "client" machines. 
Computer system 512 comprises an address/data bus 500 for communicating 
information, one or more central processors 501 coupled with the bus 500 for 
processing information and instructions, a computer readable volatile memory- 
unit 502 (e.g., random access memory, static RAM, dynamic, RAM, etc.) 
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coupled with the bus 500 for storing information and instructions for the 
central processor(s) 501, a computer readable non-volatile memory unit (e.g., 
read only memory, programmable ROM, flash memory, EPROM, EEPROM, 
etc.) coupled with the bus 500 for storing static information and instructions 
for the processor(s) 501. System 512 also includes a mass storage computer 
readable data storage device 504 such as a magnetic or optical disk and disk 
drive coupled with the bus 500 for storing information and instructions. 
Optionally, system 512 can include a display device 505 coupled to the bus 500 
for displaying information to the computer user, an alphanumeric input device 
506 including alphanumeric and function keys coupled to the bus 500 for 
communicating information and command selections to the central 
processor(s) 501, a cursor control device 507 coupled to the bus for 
communicating user input information and command selections to the central 
processor(s) 501, and a signal generating device 508 coupled to the bus 500 for 
communicating command selections to the processor(s) 501. 

Thus, embodiments of the present invention are directed towards a 
computer implemented method for maintaining software product version 
tracking. The present invention provides a solution that renders the software 
configuration management process much easier than the prior art. The 
present invention provides a solution that simplifies the changing and 
maintaining of different software product versions within a software 
development/software quality assurance environment. 

The foregoing descriptions of specific embodiments of the present 
invention have been presented for purposes of illustration and description. 
They are not intended to be exhaustive or to limit the invention to the precise 
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forms disclosed, and obviously many modifications and variations are possible 
in light of the above teaching. The embodiments were chosen and described in 
order to best explain the principles of the invention and its practical 
application, to thereby enable others skilled in the art to best utilize the 
invention and various embodiments with various modifications as are suited to 
the particular use contemplated. It is intended that the scope of the invention 
be defined by the claims appended hereto and their equivalents. 
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